package com.note.feng.leetcode.algorithms.easy.twelve;

public class ThousandTwoHundredEightyOne {
    /**
     * 1281 整数的各位积和之差
     * 给你一个整数 n，请你帮忙计算并返回该整数「各位数字之积」与「各位数字之和」的差。
     *
     * 示例 1：
     *
     * 输入：n = 234
     * 输出：15
     * 解释：
     * 各位数之积 = 2 * 3 * 4 = 24
     * 各位数之和 = 2 + 3 + 4 = 9
     * 结果 = 24 - 9 = 15
     * 示例 2：
     *
     * 输入：n = 4421
     * 输出：21
     * 解释：
     * 各位数之积 = 4 * 4 * 2 * 1 = 32
     * 各位数之和 = 4 + 4 + 2 + 1 = 11
     * 结果 = 32 - 11 = 21
     *
     * 提示：
     *
     * 1 <= n <= 10^5
     */
    /**
     * 解法：模拟
     * 遍历整数，从右往左，依次相乘和相加
     * 返回积和和的差
     * @param n
     * @return
     */
    public int subtractProductAndSum(int n) {
        int s = 0, m = 1;
        while (n > 0){
            s += n % 10;
            m *= n % 10;
            n /= 10;
        }
        return m - s;
    }
}
